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We claim: 

1 . A method for growing a hot trace in a program during the program's execution in 
a dynamiostranslator, comprising the steps of: 

identifying an initial block; and 

starting, with the initial block, growing the trace block-by-block by applying static 
branch predictioV rules until an end-of-trace condition is reached. 

2. A method flsn* growing a hot trace in a program during the program's execution in 
a dynamic translator 5 \comprising the steps of: 

identifying an imtial block as the first block in a trace to be selected; 

until an end-of-trace condition is reached, applying static branch prediction rules 
to the terminating branch of a last block in the trace to identify a next block to be added 
to the selected trace; and \ 

adding the identified next block to the selected trace. 

3. The method as defined inVlaim 2, in further comprising the step of storing the 
selected traces in a code cache. \ 

4. The method of claim 2, in which the end-of-trace condition includes at least one 
of the following conditions: \ 

(1) no prediction rule applies; (2) ktotal number of instructions in the trace 
exceeds a predetermined limit; (3) cumulative estimated prediction accuracy has dropped 
below a predetermined threshold. \ 

5. The method as defined in claim 2, in whifeh the prediction rules include both rules 
for predicting the outcomes of branch conditions akd for predicting the targets of 
branches. \ 

6. The method as defined in claim 2, in which an initial block is identified by 
maintaining execution counts for targets of branches and when an execution count 
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Exceeds a threshold, identifying as an initial block, the block that begins at the target of 
tharsbranch and extends to the next branch. 

7. TShe method claim 2, wherein said set of prediction rules comprises: 

forthe branch instruction, determining whether to add a target instruction of the 
branch instruction to the hot trace based on said set of static branch prediction rules. 

8. The method as defined in claim 7, wherein said set of static branch prediction 
rules comprises: \ 

determining if skid branch instruction is unconditional; and 

if said branch instn^ction is unconditional, then adding the target instruction of the 
branch instruction and following instructions through the next branch instruction to the 
hot trace. \ 

9. The method as defined in clami 7, wherein said set of static rules comprises: 

determining if a target instruction of said branch instruction can be determined by 
symbolically evaluating a branch condition of said branch instruction; and 

if said target instruction of said branch instruction can be determined 
symbolically, then adding the target instructionSand following instructions through the 
next branch instruction to the hot trace. \ 

10. The method as defined in claim 7, wherein sartd set of static rules comprises: 

determining if a heuristic rule can be applied to sfcud branch instruction; and 
if a heuristic rule can be applied to said branch instruction, then the branch 
instruction is determined to be Not Taken. \ 

1 1 . The method as defined in claim 9, wherein said set of statac branch prediction 
rules comprises: \ 

determining if a heuristic rule can be applied to said branch instruction; and 
if a heuristic rule can be applied to said branch instruction, then\he branch 
instruction is determined to be Not Taken. \ 
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1%. The method as defined in claim 10, further comprising the step of changing a 
count in a confidence counter if said heuristic rule can be applied to the branch 
instructton; and determining whether said confidence counter has reached a threshold 
level. \ 

13. The method as defined in claim 7, wherein said set of static rules comprises: 
determining whether said branch instruction is a procedure return; and 

if said brancnsmstruction is a procedure return, then determining if there has been 
a corresponding brancnWd link instruction on said hot trace; 

if there has been a corresponding branch and link instruction, then determining if 
there is an instruction in the not trace between said corresponding branch and link 
instruction and the procedure return that modifies a value in a link register associated 
with the corresponding branch ancNink instruction; and 

if there is no instruction that modifies the value in said link register between said 
corresponding branch and link instruction and the procedure return, then adding an 
address of a link point and following instructions up through a next branch instruction to 
the hot trace. \ 

14. The method as defined in claim 11, wherein said set of static rules comprises: 

determining whether said branch instruction \ a procedure return; and 

if said branch instruction is a procedure return, then determining if there has been 
a corresponding branch and link instruction on said hot traive; and 

if there has been a corresponding branch and link instruction, then determining if 
there is an instruction in the hot trace between said corresponding branch and link 
instruction and the procedure return that modifies a value in a link register associated 
with the corresponding branch and link instruction; and \ 

if there is no instruction that modifies the value in said link register between said 
corresponding branch and link instruction and the procedure return, then adamg an 
address of a link point and following instructions up through the next branch induction 
to the hot trace. \ 
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K The method of claim 13, further comprising the steps: 

'f ^v^toring a return address in a program stack; 

wherein said step of determining if there is an instruction that modifies the value 
in the link register comprises forward monitoring hot trace instructions between the 
corresponding branch and link instruction and the return for instructions that change a 
value in a link register associated with said corresponding branch and link instruction. 

16. The method of olaim 2, further comprising a confidence count that is incremented 
or decremented by a predetermined amount based on which static branch prediction rule 
has been applied; and \ 

if said confidence counrshas reached a second threshold level, ending the growing 
of the hot trace. \ 

17. The method of claim 2, wherein said identifying an initial block step comprises 
associating a different count with each (different target instruction in a selected set of 
target instructions and incrementing or decrementing that count each time its associated 
target instruction is executed; and \ 

identifying said target instruction as thV beginning of said initial block if the count 
associated therewith exceeds a hot threshold. \ 

18. The method of claim 17, wherein said selected set of target instructions includes 
target instructions of backwards taken branches and target instructions from an exit 
branch from a trace in a code cache. \ 

19. The method of claim 2, wherein the end-of-trace condition comprises when a total 
number of instructions in the trace exceeds a predetermined limiV 

20. A dynamic translator for growing a hot trace in a program during the program's 
execution in a dynamic translator, comprising: \ 

first logic for identifying an initial block as the first block in a trace to be selected; 
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sfe<^>nd logic for, until an end-of-trace condition is reached, applying static branch 
prediction rulb^to the terminating branch of the last block in the trace to identify a next 
block to be addecPfco the selected trace; and 

third logic for adding the identified next block to the selected trace. 

21. A computer program p*<xluct, comprising: 

a computer usable mediunvhaying computer readable program code embodied 
therein for growing a hot trace in a program during the program's execution in a dynamic 
translator, comprising 

first code for identifying an initial block^&s the first block in a trace to be selected; 

second code for, until an end-of-trace conditi&n is reached, applying static branch 
prediction rules to the terminating branch of the last blocki in the trace to identify a next 
block to be added to the selected trace; and \. 

third code for adding the identified next block tcvthe selected trace. 



